# Introduction to Digital Logic EECS/CSE 31L

#### **Assignment 4: Register**

Prepared by: Jack Melcher Student ID: 67574625

EECS Department Henry Samueli School of Engineering University of California, Irvine

February 15, 2015

## 1 Block Description

- Construct a register that can be parameterized
- Can load a given input value
- Increment the value stored in the register
- Has an asynchronous reset and synchronous reset

## 2 Input/Output Port Description

| Generic Name | Data Type | Default Value | Description      |
|--------------|-----------|---------------|------------------|
| NBIT         | INTEGER   | 32            | Size of register |

| Port name | Port size       | Port Type | Description                                         |
|-----------|-----------------|-----------|-----------------------------------------------------|
| Clk       | 1               | IN        | Triggers the register process                       |
| Rst_a     | 1               | IN        | Will reset the register when active                 |
| Rst_s     | 1               | IN        | Will reset the register when active and clock rises |
| We        | 1               | IN        | Enables writing to the register                     |
| din       | NBIT-1 downto 0 | IN        | The input value                                     |
| dout      | NBIT-1 downto 0 | OUT       | The register's stored value                         |

| Variable Name | Data Type | Port size       | Description              |
|---------------|-----------|-----------------|--------------------------|
| temp          | INTEGER   | NBIT-1 downto 0 | Aids in register process |

## 3 Design Schematics

## Truth Table:

| Clk (Rising | Rst_a | Rst_s | inc | we | Function                           |
|-------------|-------|-------|-----|----|------------------------------------|
| edge)       |       |       |     |    |                                    |
| X           | 1     | X     | X   | X  | Asynchronous Reset                 |
| 1           | 0     | 1     | X   | X  | Synchronous Reset                  |
| 1           | 0     | 0     | 0   | 1  | Load Input                         |
| 1           | 0     | 0     | 1   | 1  | Increment Value Stored in Register |

## **Design:**



## 4 Compilation

Register

```
    ■ ISE Project Navigator (P.20131013) - C.\Users\Jack\Desktop\EECS 31L\hw4\assignment4_67574625\assignment4_67574625xise - [assignment4_67574625_register.vhd]

File Edit View Project Source Process Tools Window Layout Help
 Port (clk: in STD LOGIC;

rst_a: in STD LOGIC; -- asynchronous reset

rst_s: in STD LOGIC; -- synchronous reset

inc: in STD LOGIC; -- increment

we: in STD LOGIC; -- wite enable

din: in STD LOGIC; -- write enable

din: in STD LOGIC; -- write enable

dout: out STD LOGIC VECTOR (NBIT-1 downto 0); -- input data

dout: out STD LOGIC VECTOR (NBIT-1 downto 0)); -- output data

end assignment4_67574625_register;
 View: Wigner Implementation Wigner Simulation
Hierarchy
         d assignment4_67574625

☐ xc3s700a-4fq484

       xc3s700a-41g484

assignment4_67574625_registerfil

testbenc_counter behavior (tes
                                                                         end assignment4_67574625_register;

architecture Behavioral of assignment4_67574625_register is begin

PROCESS(clk, rst_a, rst_s, inc, we)

VARIABLE temp: STD_LOGIC_VECTOR(NBIT-1 downto 0);

BEGIN

-- asynchronous reset

IF (rst_a = '1') THEN

temp:= (OTHERS => '0');

-- register functions

Elsif (clk'EVENT AND clk = '1') THEN

temp:= (OTHERS => '0');

-- write to register

ELSIF (we = '1' AND inc = '0') THEN

temp:= din;

-- increment value in register

ELSIF (we = '1' AND inc = '1') THEN

temp:= temp + 1;

END IF;

END IF;

END IF;

END FROCESS;
         ■ 1 testbench_register - behavior (tes
                 uut - assignment4_67574625_r
   ∢ III
No Processes Running
Processes: uut - assignment4_67574625_re
      > Start 📭 Design 🕦 Files 🕦 Libraries 🖫 Design Summary 🗆 🔝 testbench_register.vhd 🗀 assignment4_67574625_register.vhd 🖸 🔝 testbench_counter.vhd 🗆 📸 assignment4_67574625_counter.vhd
                                                                                                                                                                                                                                                                                                                                            + □ ē ×
   Process "Behavioral Check Syntax" completed successfully
Console Errors 🔊 Warnings 🦝 Find in Files Results
                                                                                                                                                                                                                                                                                                                           Ln 62 Col 1 VHDL
```

#### Testbench



#### 5 Elaboration

#### **Assumptions:**

• Register can store any NBIT value

Regarding how I wrote my vhdl code

- I used a process with a variable called temp
- Used sequential if and elsif statements

#### **Errors and Challenges:**

- I was having issues early on with the process statement. I didn't realize "else if" id "elsif" in VHDL
- Misusing assignment operators; tried using signal assignment operator on a variable

#### **Simulation Log:**

Started: "Simulate Behavioral Model".

Determining files marked for global include in the design...

Running fuse...

Command Line: fuse -intstyle ise -incremental -o {C:/Users/Jack/Desktop/EECS

31L/hw4/assignment4\_67574625/testbench\_register\_isim\_beh.exe} -prj

{C:/Users/Jack/Desktop/EECS 31L/hw4/assignment4\_67574625/testbench\_register\_beh.prj}

work.testbench\_register { }

Running: C:\Xilinx\14.7\ISE\_DS\ISE\bin\nt64\unwrapped\fuse.exe -intstyle ise -incremental -o C:/Users/Jack/Desktop/EECS 31L/hw4/assignment4\_67574625/testbench\_register\_isim\_beh.exe -prj C:/Users/Jack/Desktop/EECS 31L/hw4/assignment4\_67574625/testbench\_register\_beh.prj work.testbench\_register

ISim P.20131013 (signature 0x7708f090)

Number of CPUs detected in this system: 4

Turning on mult-threading, number of parallel sub-compilation jobs: 8

Determining compilation order of HDL files

Parsing VHDL file "C:/Users/Jack/Desktop/EECS

31L/hw4/assignment4\_67574625/assignment4\_67574625\_register.vhd" into library work

Parsing VHDL file "C:/Users/Jack/Desktop/EECS

31L/hw4/assignment4\_67574625/testbench\_register.vhd" into library work

Starting static elaboration

Completed static elaboration

Compiling package standard

Compiling package std\_logic\_1164

Compiling package std\_logic\_arith

Compiling package std\_logic\_unsigned

Compiling package numeric\_std

Compiling architecture behavioral of entity assignment4\_67574625\_register

[\assignment4\_67574625\_register(3...]

Compiling architecture behavior of entity testbench\_register

Time Resolution for simulation is 1ps.

Waiting for 1 sub-compilation(s) to finish...

Compiled 8 VHDL Units

Built simulation executable C:/Users/Jack/Desktop/EECS

31L/hw4/assignment4\_67574625/testbench\_register\_isim\_beh.exe

Fuse Memory Usage: 37152 KB

Fuse CPU Usage: 529 ms

Launching ISim simulation engine GUI...

"C:/Users/Jack/Desktop/EECS

31L/hw4/assignment4\_67574625/testbench\_register\_isim\_beh.exe" -intstyle ise -gui -tclbatch isim.cmd -wdb "C:/Users/Jack/Desktop/EECS

31L/hw4/assignment4\_67574625/testbench\_register\_isim\_beh.wdb"

ISim simulation engine GUI launched successfully

Process "Simulate Behavioral Model" completed successfully

## 6 Waveforms

Full Waveform Snapshot



### Snapshots of Waveform

#### Reset (asynchronous)

| Name           | Value                                   |            | 206 ns         | 208 ns       | 210 ns | <br>212 ns | 214 ns         | 216 ns            | 218 ns          | 220 ns |
|----------------|-----------------------------------------|------------|----------------|--------------|--------|------------|----------------|-------------------|-----------------|--------|
| ∏e clk         | 0                                       |            |                |              |        |            |                |                   |                 |        |
| ∏e rst_a       | 1                                       |            |                |              |        |            |                |                   |                 |        |
| Ve rst_s       | 0                                       |            |                |              |        |            |                |                   |                 |        |
| Te inc         | 0                                       |            |                |              |        |            |                |                   |                 |        |
| Te we          | 1                                       |            |                |              |        |            |                |                   |                 |        |
| ▶ ■ din[31:0]  | 01011100001101010100011001100110        |            |                |              |        | 01011100   | 00110101010001 | 1001100110        |                 |        |
| ▶ ■ dout[31:0] | 000000000000000000000000000000000000000 | 01 × 01011 | 10000110101010 | 011001101010 | K      |            | 0              | 00000000000000000 | 000000000000000 | 00     |
| □ clk_period   | 10000 ps                                |            |                |              |        |            | 10000 ps       |                   |                 |        |
| -              |                                         |            |                |              |        |            |                |                   |                 |        |

#### Reset (synchronous)

| Name           | Value                                   |           | 115 ns           | 120 ns   | 125 ns | 130 ns         | 135 ns           | 140 ns   |
|----------------|-----------------------------------------|-----------|------------------|----------|--------|----------------|------------------|----------|
| Va clk         | 1                                       |           |                  |          |        |                |                  |          |
| Va rst_a       | 0                                       |           |                  |          |        |                |                  |          |
| Ve rst_s       | 1                                       |           |                  |          |        |                |                  |          |
| ₹ inc          | 1                                       |           |                  |          |        |                |                  |          |
| Va we          | 0                                       |           |                  |          |        |                |                  |          |
| ▶ No din[31:0] | 01011100001101010100011001100110        |           |                  |          |        | 010111000      | 11010101000110   | 01100110 |
| ▶ 🥷 dout[31:0] | 000000000000000000000000000000000000000 | 010111000 | 0110101010000110 | 01101010 | 00     | 00000000000000 | 0000000000000000 | 00       |
| le clk_period  | 10000 ps                                |           |                  |          |        |                | 10000 ps         |          |
| -              |                                         |           |                  |          |        |                |                  |          |

#### Load input



#### Increment



#### Hold (write enable off)

